<?
/***************************************************************************
*
* IMPORTANT: This is a commercial product made by BoonEx Ltd. and cannot be modified for other than personal usage.
* This product cannot be redistributed for free or a fee without written permission from BoonEx Ltd.
* This notice may not be removed from the source code.
*
***************************************************************************/
require_once(BX_DIRECTORY_PATH_INC . "utils.inc.php");
require_once(BX_DIRECTORY_PATH_INC . "membership_levels.inc.php");
require_once(BX_DIRECTORY_PATH_CLASSES . "BxDolInstallerUtils.php");
require_once(BX_DIRECTORY_PATH_CLASSES . "BxDolPermalinks.php");

function rzGetMembershipId($sUserId)
{
	$aMembership = getMemberMembershipInfo_current($sUserId);
	return $aMembership["ID"];
}

function rzGetMemberships()
{
	$aMemberships = array();
	$rResult = getResult("SELECT * FROM `sys_acl_levels`");
	for($i=0; $i<mysql_num_rows($rResult); $i++)
	{
		$aMembership = mysql_fetch_assoc($rResult);
		$aMemberships[$aMembership["ID"]] = $aMembership["Name"];
	}
	return $aMemberships;
}

function getAdminIds()
{
	$rResult = getResult("SELECT `ID` FROM `Profiles` WHERE (`Role` & 2)");
	$aIds = array();
	for($i=0; $i<mysql_num_rows($rResult); $i++)
	{
		$aId = mysql_fetch_assoc($rResult);
		$aIds[] = (int)$aId['ID'];
	}
	return $aIds;
}

function isUserAdmin($iId)
{
	$aIds = getAdminIds();
	return in_array((int)$iId, $aIds);
}

function getUserVideoLink()
{
	global $sRootURL;
	if(BxDolInstallerUtils::isModuleInstalled("videos"))
	{
		$oDolPermalinks = new BxDolPermalinks();
		return $sRootURL . $oDolPermalinks->permalink("modules?r=videos/") . "browse/owner/#nick#";
	}
	return "";
}

function getUserMusicLink()
{
	global $sRootURL;
	if(BxDolInstallerUtils::isModuleInstalled("sounds"))
	{
		$oDolPermalinks = new BxDolPermalinks();
		return $sRootURL . $oDolPermalinks->permalink("modules?r=sounds/") . "browse/owner/#nick#";
	}
	return "";
}

function blockUser($iUserId, $iBlockedId, $bBlock)
{
	bx_import('BxDolAlerts');

	if($bBlock)
	{
		getResult("REPLACE INTO `sys_block_list` SET `ID` = '" . $iUserId . "', `Profile` = '" . $iBlockedId . "'");
		$oZ = new BxDolAlerts('block', 'add', $iBlockedId, $iUserId);
	}
	else
	{
		getResult("DELETE FROM `sys_block_list` WHERE `ID` = '" . $iUserId . "' AND `Profile` = '" . $iBlockedId . "'");
		$oZ = new BxDolAlerts('block', 'delete', $iBlockedId, $iUserId);
	}
	$oZ->alert();
}

function getBlockingList($sId, $bBlocking)
{
	$sSelectField = $bBlocking ? "ID" : "Profile";
	$sWhereField = $bBlocking ? "Profile" : "ID";
	
	$sType = getValue("SELECT `Type` FROM `" . MODULE_DB_PREFIX . "Profiles` WHERE `ID`='" . $sId . "' LIMIT 1");
	if(empty($sType))
		$sType = CHAT_TYPE_FULL;
	$aAllTypes = array(CHAT_TYPE_FULL, CHAT_TYPE_MODER, CHAT_TYPE_ADMIN);
	$iTypeIndex = array_search($sType, $aAllTypes);
	if($bBlocking)
		array_splice($aAllTypes, 0, $iTypeIndex);
	else
		array_splice($aAllTypes, $iTypeIndex+1, count($aAllTypes)-$iTypeIndex-1);
	$sTypes = count($aAllTypes) > 0 ? " AND `profiles`.`Type` IN ('" . implode("','", $aAllTypes) . "')" : "";
	$rResult = getResult("SELECT `blocked`.`" . $sSelectField . "` AS `Member` FROM `sys_block_list` AS `blocked` LEFT JOIN `" . MODULE_DB_PREFIX . "Profiles` AS `profiles` ON `blocked`.`" . $sSelectField . "`=`profiles`.`ID` WHERE `blocked`.`" . $sWhereField . "`='" . $sId . "'" . $sTypes);
	
	$aUsers = array();
	for($i=0; $i<mysql_num_rows($rResult); $i++)
	{
		$aBlocked = mysql_fetch_assoc($rResult);
		$aUsers[] = $aBlocked["Member"];
	}
	return $aUsers;
}
?>